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UNTRACEABLE ELECTRONIC CASH 
Backgroun d of- the Invention 
5 The invention generally relates to electronic cash 

' systems * 

The ultimate intuitive goal of an electronic cash 
system is to combine the best features of physical cash 
(privacy, anonymity, unforgeability) with the best 

10 features of electronic commerce (speed, ease and 
potential security of transport and storage) . The 
fundamental difficulty with attempting to implement 
anonymous electronic cash, however, is simple to state: 
if the possessor of an electronic "coin 11 is not 

15 identified in two successive transactions, then how is he 
or she to be prevented from acting as if the first 
transaction never occurred, and spending the same coin 
again? The first proposed solution to this problem was 
presented by Chaum, Fiat and Naor (see D. Chaum, A Fiat 

20 and M. Naor, Untraceable Electronic Cash, Proc. CRYPTO 
'88, Springer-Verlag (1990), pp. 319-327.) , and was based 
on the premise that it would be sufficient for such 
M double spending" to be detected, and the spender 
identified, upon presentation of the same "electronic 

25 coin" twice to the central bank. This premise has also 
been used in a number of other, all with the advantage 
that the bank need not be involved in each transaction. 
Practically speaking, however, this premise has enormous 
drawbacks. Fraudulent transactions are detected only 

30 long after they have taken place, and if the perpetrator 
can be confident of not being brought to justice (either 
by being inaccessible, or by managing to use someone 
else's identity and cash), then he or she can double- 
spend at will. 
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However, if such fraudulent use of electronic cash 
is to be prevented, then some authority must somehow be 
involved in each transaction as it occurs, so as to be 
able to recognize and alert targets of double-spending. 
5 How, then, is anonymity to be preserved? One approach is 
to rely on tamper-resistant hardware to force spenders to 
behave "honestly" (ie. , not to double-spend) (see, for 
example, S. Even, O. Goldreich and Y. Yacobi, Electronic 
Wallet, Proc. CRYPTO '83, Plenum Press (1984), pp. 383- 

10 386.)* Schemes based on this premise are, however, 
extremely "brittle". If anyone eyer succeeds in 
tampering with the hardware, then not only is that person 
capable of double-spending, but anyone, anywhere who 
obtains (e.g. purchases, perhaps) the information hidden 

15 in the hardware can spend arbitrarily high amounts at 
will. Current tamper resistance technology is far from 
being dependable enough to be trusted to thwart such an 
enormous risk. 

Another approach is cryptographic. For example, 

20 under certain very strong cryptographic assumptions, it 
is possible to construct protocols that create "blinded" 
cash — information which can be recognized later as valid 
cash, but cannot be connected with any particular run of 
the protocol- (See, for example, D. Chaum, Privacy 

25 Protected Payments — Unconditional Payer and/or Payee 
Untraceability , SMART CARD 2000: The Future of IC 
Cards — Proc. IFIP WG 11.6 Int'l Conf . , North-Holland 
(1989), pp. 69-93; and D. Chaum, Online Cash Checks, 
Proc. EDROCRYPT '89, Springer-Verlag (1989), pp. 288- 

30 293.) 

Summary of the Invention 
We present a simple, practical online electronic 
cash system based on the assumption of a network in which 
anonymous, untraceable communication is possible. In 
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general, the invention uses two simple primitives, namely 
a one-way function and a signature scheme. These are 
both well known in the art and descriptions can be found 
in publicly available literature on cryptography, e.g. 
5 Applied Cryptography . Bruce Schneier, John Wiley & Sons, 
Inc. (1994). The system protects the anonymity of 
spenders as well as guaranteeing their electronic coins' 
validity, and the coins used are unforgeable and cannot 
be spent more than once. 

10 In general, in one aspect, the invention is an 

electronic cash protocol including the steps of using a 
one-way function fjCx) to generate an image f^XjJ from a 
pre image x a ; sending the image fiCXj) in an unblinded form 
to a second party; and receiving from the second party a 

15 note including a digital signature. The received signed 
note represents a commitment by the second party to 
credit a predetermined amount of money to a first 
presenter of the preimage x x to the second party. 

Preferred embodiments include the following 

20 features. The electronic cash protocol also includes 
sending the preimage x x to a third party as payment for 
purchase of goods or services from the third party. 
Alternatively, it further includes selecting a second 
preimage x 2 ; using a second one-way function f 2 (x)to 

25 generate a second image f 2 (x 2 ) from the second preimage 
x 2 ; sending the first preimage x x and the unblinded form 
of the second image f 2 (x 2 ) to the second party; and 
receiving from the second party a note including a 
digital signature, the note representing a commitment by 

30 the second party to credit the predetermined amount of 
money to a first presenter of the second preimage x 2 to 
the second party. In both cases, f^x) and f 2 (x) are the 
same function. In the latter case, the sending of the 
first preimage x, and the unblinded form of the second 
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image f 2 (x 2 ) to the second party is performed anonymously 
and the second party is a bank. 

Also in preferred embodiments, the protocol 
includes the steps of concatenating a signature key of a 
5 third party with the first preimage x x to form a block of 
information; encrypting the block of information by using 

an encryption key of the second party to generate an 
encrypted block of information; and sending the encrypted 
block of information to the third party. 

10 In general, in another aspect, the invention is an 

electronic cash protocol including the steps of receiving 
a first preimage x x from a first party, wherein the 
preimage x x produces a first image f^x^ when processed 
by a first one-way function f x (x) and there being 

15 associated with said first preimage x x a commitment by a 
second party to credit a predetermined amount of money to 
a first presenter to the second party of said first 
preimage x x ; selecting a second preimage x 2 ; using a 
second one-way function f 2 (x)to generate a second image 

20 f 2 (x 2 ) from the second preimage x 2 ; sending the first 
preimage x x and an unblinded form of the second image 
f 2 (x 2 ) to the second party; and receiving from the second 
party a note including a digital signature, wherein the 
note represents a commitment by the second party to 

25 credit the predetermined amount of money to a first 

presenter of the second preimage x 2 to the second party. 

In general, in yet another aspect, the invention 
is an electronic cash protocol including the steps of 
receiving from a first party an encrypted block of 

30 information, wherein the block of encrypted information 
was generated by first concatenating a public signature 
key of a second party with a first preimage x x to form a 
block of information and then encrypting the block of 
information by using an encryption key of a third party; 
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selecting a second preimage x 2 ; using a second one-way 
function f 2 (x) to generate an image f (x 2 ) from the 
preimage x 2 ; forming a message including the encrypted 
block of information along with the image f (x 2 ) in an 
5 unblinded form; sending the message to the third party; 
and receiving from the third party a signed note 
including a digital signature, wherein the note 
represents a commitment by the third party to credit a 
predetermined amount of money to a first presenter of the 

10 preimage x 2 to the third party. 

In general, in still another aspect, the invention 
is an electronic cash protocol including the steps of 
receiving from a first entity an unblinded form of an 
image fi(x x ) that was generated by applying a one-way 

15 function f x (x) to a preimage x x ; generating a message 
which contains a commitment to credit a predetermined 
amount of money to a first presenter of the preimage x x ; 
signing the message with a digital signature; and sending 
the message along with the digital signature to the first 

20 party. 

In preferred embodiments, the electronic cash 
protocol also includes subsequently receiving the 
preimage x x from a third party; checking a database for 
the preimage x x ; if the preimage x x is not found in the 

25 database, crediting the third party with the 

predetermined amount of money; and adding the preimage x x 
to the database. Alternatively, the protocol includes 
subsequently receiving the preimage x x and an unblinded 
image f 2 (x 2 ) from a third party, wherein the unblinded 

30 image f 2 (x 2 ) was generated by applying a one-way function 
f 2 (x) to a preimage x 2 ; checking a database for the 
preimage x x ; if the preimage x x is not found in the 
database, generating a signed note including a digital 
signature, wherein the note represents a commitment to 

35 credit the predetermined amount of money to a first 
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presenter of the preimage x 2 ; and adding the preimage x a 
to the database. 

Also in preferred embodiments, the invention 
features receiving a message from a second party, wherein 
5 the message was generated by concatenating an encryption 
key of a third party with a first preimage x x to form a 
block of information, by encrypting the block of 
information by using a first encryption key to generate 
an encrypted first block, and by concatenating an 

10 unblinded image f 2 (x 2 ) to the encrypted first block of 
information, wherein the unblinded image f 2 (x 2 ) was 
generated by using a one-way function f 2 (x) to generate 
an image f 2 (x 2 ) from a preimage x 2 . It further features 
decrypting the encrypted first block of information; 

15 generating a note including a digital signature, wherein 
the note represents a commitment to credit a 
predetermined amount of money to a first presenter of the 
preimage x 2 ; and sending the note to the second party . 

In general, in yet another aspect, the invention 

20 is an electronic cash protocol including the steps of 
sending an unblinded image f 2 (x 2 ) to a second party, 
wherein the unblinded image f 2 (x 2 ) was generated by 
applying a one-way function f 2 (x) to a preimage x 2 ; 
receiving a signed note from the second party, wherein 

25 the unblinded note includes a digital signature and 
represents a commitment to credit the predetermined 
amount of money to a first presenter of the preimage x 2 ; 
and in response to receiving the unblinded note from the 
second party, authorizing the delivery of goods and/or 

30 services to a third party. 

The invention offers a simple, inexpensive way of 
doing cash-like transactions where the item of exchange 
(i.e., the withdrawn coin) has the properties of actual 
cash. For example, it is: (1) more or less anonymous; 
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(2) secure; (3) inexpensive to use; and (4) easy to carry 
around and exchange* 

Parties are protected against a dishonest bank's 
reneging on withdrawn coins by the fact that they keep 
5 secret the value x 1 for a particular coin until it is 
spent. As long as a particular coin f (x x ) is deposited 
publicly and non-anonymously, the bank can be required to 
honor it unless it can supply the associated x x . Of 
course , the bank can renege on an anonymously exchanged 

10 coin f (x x ) during the actual exchange, by claiming upon 
receiving x x that the coin has already been spent. 
However, the bank cannot possibly know who is being 
cheated by such a "dine and dash" ploy, and is therefore 
vulnerable to monitoring and public exposure. 

15 Finally, banks themselves are protected against 

counterfeiting by the security of the digital signature 
scheme used to sign electronic coins. Moreover, they are 
protected against "double-spending" (or "double deposit") 
by their ability to store x x values for coins in 

20 perpetuity. 

Other advantages and features will become apparent 
from the following description of the preferred 
embodiment and from the claims. 

Brief Description of the Drawings 
25 Fig. 1 is a diagram of a non-anonymous withdrawal 

protocol ; 

Fig. 2 is a diagram of an anonymous exchange 
protocol ; 

Fig. 3 is a diagram of an anonymous purchase 
30 protocol; 

Fig. 4 is a diagram of a non-anonymous deposit 
protocol ; 

Fig. 5 is a diagram of an anonymous alternate 
payment protocol; 
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anonymous "drop" payment or 

Fig. 7 is a diagram 
protocol . 
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of an anonymous or non- 
money order protocol; and 
of an encrypted money order 



5 Descripti on of the Preferred Embodiments 

The ability to communicate anonymously is in some 
sense necessary a priori if anonymous cash transactions 
are to occur , since information about a party 's 
communications will obviously reveal information about 

10 the party's business dealings. In practice, the 

anonymity of communication may be based on nothing more 
than confidence that the telephone company safeguards the 
confidentiality of its system. Alternatively, parties 
may trust in one or more "anonymous remailers" to obscure 

15 their identifies, or rely on an implementation of one of 
the other techniques from the publicly available 
literature . 

Suppose, not only that communications between 
parties are anonymous with respect to third parties, but 

20 also that the communicating parties are anonymous to each 
other. (In typical implementations, the latter condition 
is a natural consequence of the former, barring self- 
identif ication. ) A simple, somewhat anonymous electronic 
cash protocol in such a setting is shown in Fig. 1. 

25 In the following descriptions of various protocols 

(see Figs. 1-7), we generally refer to three parties, 
namely, a Customer 10, a Vendor 20, and a Bank 30. 
Customer 10 is of course generally representative of the 
payor and Vendor 20 is generally representative of the 

30 payee. It should be understood, however, that these 

designations are chosen for purposes of clarity and that 
they are not meant to limit the scope of the invention. 
It would be just as valid to have referred to them as 
party A, party B and Party C. 
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In the figures, the different entities are 
represented by blocks and the transfers of information 
from one entity to another are indicated by lines 
interconnecting the appropriate blocks. Each line 
5 represents a transfer of certain information from one 
entity to another in the direction indicated by an arrow 
at the end of the line. The information that is 
transferred is summarized symbolically below the lines. 

Though each block is labeled and will be described 

10 below as representing a particular entity, it can be 
implemented by a computing device which performs the 
computations and the communications that are carried out 
by that entity. The computing devices might be any of a 
k large variety of electronic devices including, for • 

15 example, a personal computer, a PCMCIA card, a PDI, a 
smart-card, a palm-top computer, or a more powerful 
workstation, just to name a few. The banks side of the 
protocols that are described below can be implemented by 
a server programmed to handle electronic transactions, 

20 similar to those which currently handle ATM transactions. 
The server would have multiple telephone lines coming 
into it and include data storage capability for storing 
the relevant data. 

It should of course also be understood that the 

25 computing devices include, either internally or 

externally, all of the memory that is required for the 
data and programs that are involved in implementing the 
protocols. Further more, they include devices (e.g. a 
modem) which enable them to communicate with other 

30 computing devices. In addition, the communications media 
over which the transfers of information take place can 
also be any of a large number of possibilities, including 
telephone lines, cable, the Internet, satellite 
transmissions, or radio transmissions, for example. In 

35 other words, it is not intended that the invention be 



WO 97/09688 



PCT/US96/14078 



- 10 - 

limited with regard to either the types of devices that 
are used or the methods of communication that are 
employed. The possibilities and combinations are limited 
only by ones imagination. 
5 For the following protocols, it is assumed that 

Bank 30 chooses and makes publicly available a one-way 
function f(x). Alternatively, such a function could be 
made publicly available by any party so long as all 
parties to the transactions can access and use it. In 

10 general, by a one-way function, we mean a function f (x) 
such that using x x produces f (x x ) and given f (x x ) you 
cannot determine x a . In the following description, x a 
will also be referred to as a preimage of f (x x ) and f(x x ) 
will be referred to as an image of x x . 

15 In practice, perfect one-way functions may not 

actually exist. That is, for all functions now believed 
to be one way functions, there may eventually be 
sufficient computing power or techniques for determining 
x x given f(x x ). Thus, by the phrase one-way function, we 

20 mean to also include those functions for which it is very 
difficult, but not necessarily impossible, to compute x x 
by knowing f(x a ). 

The one-way function can be any one of a number of 
standard hash functions (e.g. MD5, SUA, etc.). In 

25 addition, it one could use several one-way functions and 
concatenate them. There are a lot of one-way functions 
known in the art and typically, many of them are easy to 
compute and thus they can be implemented on a smart card. 

With that background, the various protocols which 

30 embody the invention will now be described, starting with 
a withdrawal protocol during which a customer obtains 
"cash" from the bank. 
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Withdrawal Protocol 

A withdrawal is performed in the 'manner shown in 
Fig, 1 Customer 10 chooses a random number x x and uses 
f (x) to generate an image of x x . The value xl is a 
5 random string obtained from a random number generator to 
which some post processing may optionally be applied. It 
may be, for example, 128 bits long. Customer 10 keeps it 
secret until a payment takes place and then it is sent as 
the payment. 

10 Customer 10 then withdraws a coin (non- 

anonymously) from Bank 30 by requesting that Bank 30 
associate a monetary value with f(x x ). Bank 30 complies 
by digitally signing a statement to that effect, thus 
"certifying" f (x x ) as a valid coin and debits an account 
15 which Customer 10 maintains at Bank 30 by the amount of 
the value of the coin. In other words, Bank 30 issues a 
statement or representation which indicates in effect 
that "The first presenter of the preimage of f (x x ) will 
be credited an amount Z" and then Bank 30 signs or 
20 certifies that representation. 

Techniques for signing or certifying information 
(e.g. by using a private key-public key pair) and the use 
of digital signatures are well known in the art. For 
further details, refer to any of the widely recognized 
25 references in the field, e.g. Applied Cryptography by 
Bruce Schneier, John Wiley & Sons, Inc., (1994). 

In general, a signature scheme is a way of tagging 
a script. It typically uses a public key-private key 
pair. Public-private keys can be implemented using one- 
30 way functions, although a somewhat more practical 

approach is to use a trap door function, which tends to 
be more efficient (e.g. see RSA, DSS, ElGamal algorithms 
described by Schneier) . The private key is used to 
encrypt the script or a hash of the script to produce a 
35 digital signature that is then appended to the script. 
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The digital signature represents a signature of the 
entity which owns the private key since no other entity 
can generate such a signature from that script. If a 
second entity can decrypt the tag using the public key, 
5 it knows that the signature was generated by the entity 
which owns the private key. 

Obviously , for certification to work, it is 
assumed that everyone has and trusts the signing 
authority 1 s public key and has confidence that the 

10 private key has not been compromised. 

By publicizing its public key and appending 
digital signatures to a representation that Bank 30 will 
pay a specified sum to the entity that first presents a 
preimage of ti* x ) § Bank 30 links itself , unambiguously to 

15 its commitment, and protects itself against would-be 
forgers. 

The certified representation that is generated by 
the bank is designated herein as CfffXj)), also referred 
to herein as a note. This note is returned to Customer 
20 10. In addition, it can be made publicly available since 
it is of no value to anybody who does not know Xj. 

Exchange Protocol 

At any time, a party (e.g. Customer 10 or Vendor 
20) can anonymously "exchange" a coin at Bank 30. 

25 Indeed, it is particularly important to do this 

immediately after receiving a coin from another party to 
minimize the risk that somebody else will supply x x to 
Bank 30 before the bona fide recipient of the coin. A 
dishonest party could try to send the coin multiple times 

30 by giving xl to multiple parties. If that happens, the 
first recipient to reach Bank 30 will receive its value 
and all other recipients of the coin will not be able to 
exchange it for another coin. For Vendor 20, the timing 
of the exchange is less crucial because presumably Vendor 
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20 will not deliver the goods or services that are being 
purchased until being assured that the coin that was 
received is still valid. 

Referring to Fig. 2, assuming that Customer 10 
5 wishes to anonymously exchange a coin, Customer 10 

supplies to Bank 30 x : and another image of the function, 
f(x 2 ), for some randomly chosen x 2 . In other words. 
Customer 10 attempts to make a withdrawal as described 
earlier but simultaneously supplies the amount that is 

10 being withdrawn as represented by x x . Bank 30 simply 
certifies f (x 2 ) and keeps x x in a database 40 as proof 
that f (x x ) has already been "spent". It is this exchange 
that prevents double spending of x x . 

Since f (x x ) and C(f (x x >) are already in the 

15 possession of Bank 30, the sending of that information to 
Bank 30 along with x x and f (x 2 ) is optional. 

If the Bank 1 s side of the protocol is implemented 
on a server, it automatically stores the x^ s that are 
received. And each time Bank 30 receives another Xj, it 

20 first checks it against the x^ s that have already been 
cashed in (i.e., received). 

One can use a series of exchange transactions to 
obscure who actually is spending the coin. Note that 
during an exchange transaction, only f (x 2 ) need be 

25 disclosed but not the owner of x 2 . Unlike alternative 
approaches to achieving anonymity, blinding of the coin 
or other aspects of the transaction is not necessary. 
Indeed, it is desirable that f (x x ) not be blinded but be 
made publicly known. 

30 Whatever steps one wishes to take to secure 

anonymity of communication is sufficient to secure 
anonymity of the transaction (i.e., achieving anonymity 
is possible but it is also optional) . 

This procedure can also be used to make change for 

35 a coin of a given value. Instead of sending f(x 2 ), the 
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party seeking the change can send multiple f (x)' s, e.g. 
f(x 2 ), f(x 3 ), f(x 4 ), each for a particular value and the 
total of which equals the value associated with t(x x ). 
The bank returns multiple signed notes, C(f(x i )). 

5 Purchase Protocol 

Referring to Fig. 3, the actual spending of coins 
uses a protocol that is similar to the exchange protocol* 
The spending party (e.g. Customer 10) passes x A to the 
receiving party (e.g. Vendor 20). Since it is likely 

10 that Vendor 20 does not have direct and immediate access 
to f(x x ) and C(f(x 1 )), Customer 10 also includes this 
information as part of the transaction. Vendor 20 then 
immediately calls Bank 30 and exchanges x x for a "fresh" 
coin, assuming that Bank 30 first verifies that it has 

15 not previously been spent. Vendor 20 uses the exchange 
protocol illustrated in Fig. 2 to perform this exchange. 
Assuming that the exchange was successful, Vendor 20 then 
delivers to Customer 10 the goods and/or services that 
were purchased. 

20 Deposit Protocol 

Referring to Fig. 4, unspent coins can also be 
deposited non-anonymous ly with Bank 30 at any time. For 
example, when Vendor 20 wishes to deposit a coin f (x x ) 
that it has not spent, it sends x x to Bank along with a 

25 deposit request. Vendor 20 may also optionally send 
f(x 1 ) as well as the note C(f (x x ) ) . 

Upon receiving x x and the deposit request, Bank 30 
checks its database to determine whether x 2 has been 
previously presented to the Bank. Of course, if it had 

30 been previously presented, Bank 30 will not credit the 
Vendor 1 s account and will report to Vendor 20 that it is 
not a valid coin. If Bank 30 has not previously received 
x 1# it credits the Vendor's account with the appropriate 
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amount $nd sends a deposit receipt to Vendor 20 
confirming that a credit has been entered. 



Extensions to the Protocols 

The exchange and payment protocols in the above- 
5 described electronic cash scheme permit a number of 

variations, which can be tailored to the available means 
of communication and the desired levels of anonymity. 
For example, referring to Fig. 5, if Customer 10 has 
easier access to Bank 30 than Vendor 20, then Vendor 20 
10 can first supply an f (x 2 ) to Customer 10, who then 

performs the exchange protocol for Vendor 20 and returns 
the signed coin, i.e., C(f(x 2 )), as proof of payment. As 
mentioned previously, the exchange protocol may be 
performed anonymously. 
15 Alternatively, if both Customer 10 and Vendor 20 

have better communications access to Bank 30 than to each 
other, then the parties may use a "drop" payment 
protocol, such as is illustrated in Fig. 6. In 
accordance with this protocol, Customer 10 drops off the 
20 payment at Bank 30 for Vendor 20 and Vendor 20 
subsequently picks up the payment from Bank 30. 

The steps of the "drop" payment protocol are as 
follows. First, Customer 10 supplies an x 2 for a valid 
coin of a specific amount to Bank 30, along with a public 
25 signature key p of Vendor 20, and other information 
relating to the transaction. For example, among the 
other information Customer 10 might wish to identify the 
goods being purchased, to identify the transaction and/or 
the vendor, and to indicate the Customer' s declared 
30 intentions regarding payment, thereby essentially turning 
the cash into a kind of "electronic money order". 
Optionally, Customer 10 can also send f(x a ) and the note 
C(f(xO), but as pointed out earlier, since this 
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information is already available to Bank 30, sending it 
may not be necessary. 

Note that the a record that may be assembled from 
the other information supplied by Customer 10 may be of 
5 particular use in remote payment settings, where the 
nature of the transaction is not otherwise implicit in 
the action of payment itself, as is typically the case 
for in-person payments. 

If Vendor 20 does not wish to remain anonymous, 

10 the public signature key may be publicly associated with 
the identity of Vendor 20; or if anonymity is desired, 
the public signature key can be a special-purpose public 
signature key with no associated identity. In the latter 
case, the public key is passed confidentially to trusted 

15 acquaintances or simply publicized under a pseudonym. 

Bank 30 agrees to assign the amount associated 
with x x to. the first coin f(x L ) presented to it that it is 
also signed using the private signature key that 
corresponds with the previously-delivered public 

20 signature key p. Thus, to obtain the payment for the 
goods that Customer 10 wishes to purchase, Vendor 20 
simply makes a withdrawal from Bank 30 using the protocol 
previously described in connection with Fig. 1. That is, 
Vendor 20 randomly selects an x 2 , and uses f(x) to 

25 generate its image f(x 2 ). In this instance, however, 
Vendor 20 signs f (x 2 ) with its private signature key 
before sending f (x 2 ) to Bank 30. In addition, in this 
case the withdrawal is not from the Vendor 1 s account but 
is simply a transfer of the amount previously supplied by 

30 Customer 10. 

Bank 30 uses the Vendor 1 s public signature key to 
verify that f(x 2 ) is signed by Vendor 20 (i.e., by the 
party to whom the money transfer is to be made) • Upon 
confirming the signature on f(x 2 ), Bank 30 issues a note 

35 C(f(x 2 )) which it sends to Vendor 20. 
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After Vendor 20 receives the note C(f(x 2 )) 
confirming that the money has been received. Vendor 20 
sends the goods to Customer 10 . 

Of course, theoretically Bank 30 could cheat by 
5 simply keeping the money instead of assigning it to the 
payee. However, we rely on the anonymity of the payer or 
at least the possibility that the payer may be exposing 
the transaction to public monitoring to keep Bank 30 
honest . 

10 In a. setting where communications among the 

parties may be intercepted, there are a number of ways of 
securing the exchange protocols and, in particular, the 
secret x value passed therein from eavesdroppers. The 
most natural method is public key encryption. If parties 

15 know each others public encryption keys, as well as the 
banks, then all of the above protocols can function 
equally well in the eavesdropper-threatened setting, as 
long as every message, except those sent by Bank 30, is 
encrypted using the receivers public encryption key or 

20 using a symmetric "session key" encrypted using the 

receiver's public encryption key. The bank 1 s messages, 
of course, can be considered non-confidential, since they 
consist only of signed coins of the form t{x L ) , with x L 
kept secret by someone else. The use of message 

25 authentication codes, or MAC'S, with each encryption 

makes it possible also to ensure that the message is not 
even tampered with by someone other than the sender 
before arriving at its destination. 

The use of public-key encryption also makes 

30 possible another kind of "electronic money order." In 
this case, which is illustrated in Fig. 7 and referred to 
generally as an encrypted money order protocol. Customer 
10 encrypts the secret x L value for some valid electronic 
coin, along with the public key p of Vendor 20 and any 

35 other desired identity or transaction information, as in 
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the case of the previous "drop" protocol. Customer 10 
encrypts this information by using the public encryption 
key of the bank or by using a session key which is then 
encrypted using the public encryption key of the bank. 
5 Customer 10 then sends the encrypted data directly to 
Vendor 20. 

To "cash" it, Vendor 20 selects a random value x 2 , 
generates its image f (x 2 ) and appends f (x 2 ) to the message 
E that was received from Customer 10, As before, f (x 2 ) 

10 is to be signed by the bank so that it will represent the 
transfer of cash to Vendor 20. Vendor 20 signs the 
complete message (or at least f(x 2 )) using the private 
signature key associated with public signature p, and 
passes E, f (x 2 ) and the signature to Bank 30. 

15 Optionally, Vendor 20 may further encrypt this message in 
the manner described before, i.e., using the banks 
encryption key and possibly an additional symmetric key. 

After Bank 30 has decrypted the message from 
Vendor 20 by using its private key, it then checks its 

20 database does not already have x x stored in it, and if it 
is not found Bank 30 stores x x . Bank 30 then generates a 
note C(f(x2)) representing a cash transfer to Vendor 20 
in the amount of the value associated with f (x x ) . The 
note is then sent to Vendor 20 which after receipt and 

25 verification sends the purchased goods to Customer 10. 
In effect, this encrypted last protocol is 
identical to the previous one. The addition of 
encryption has simply permitted the payer to pass the 
"money order" via the payee, while ensuring that the 

30 secret and additional information provided by the payer 
is not tampered with. 

It may be beneficial for the note, C(f(x i )), to 
include an expiration date. In that case, the stored 
x L ' s in the database of Bank 30 will not grow too large. 

35 That is, x,' s will not have to kept around in the Bank 1 s 
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database forever. To prevent the value of the coins from 
expiring, the smart card (or whatever equipment is 
handling the customer' s transactions) could automatically 
exchange the old coins for new ones with a new expiration 
5 date. 

The expiration date also makes the money 
refundable- If a user 1 s smartcard breaks and all of the 
Xj/ s are lost, the user can simply present the f(x L ) to 
Bank 30 with the request that if they are not claimed 

10 within 3 months after the expiration date, then the 
customer wants to be credited with the amount of the 
value of the coins. For this to work, however, during 
the original communication with Bank 30 at which time the 
coins are withdrawn, Customer 10 must identify himself or 

15 herself. 

The customer side of the protocols can be easily 
implemented using a smartcard since only the x t ' s need to 
be stored and they typically will not require a lot of 
memory. To prevent theft of the x L * s by somebody who 

20 steal the smartcard, a PIN can be used in the smartcard 
which is secret and which must be entered by the user 
before any of the Xj/ s can be accessed. 

Note that it was also assumed that all of the 
interactions that were described above were automated. 

25 That is, they were automatically carried out by an 

appropriately programmed computer or processor that was 
under the control of the party for whom the transaction 
is being implemented. 

Other embodiments are within the following claims. 

30 For example, another way to link identifying information 
to electronic coins is to use the secret value x £ to 
perform the linking. In the above-description, it was 
assumed that the secret values x L are generated randomly 
by the coin's creator. The secret value can, however, be 

35 generated as the image of some identifying data under a 
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one-way function h(x), which could perhaps be the same 
function f (x) that is used in the construction of normal 
electronic coins. The identifying information might 
include the purpose and date of the payment and the name 
5 of the payer and the intended payee — in short, all of 
the information that the payer might have wished the bank 
to archive. This information would then be passed 
through h(x) to generate an x i; which serves as the 
secret value. 

10 In this case, there would be no need for the bank 

to archive transaction information received with 
electronic payments in either the "drop" or "electronic 
money order" protocols described above. In fact, all 
that is required is that the payment be labeled as 

15 requiring that the payee be non-anonymous. As long as 
the bank positively identifies the payee and keeps normal 
records of the transaction, including the payee's 
identity, the payer can later demonstrate "payership" by 
publicly revealing the pre- image of x L under f (x) , which 

20 as indicated above might include information regarding 
the purpose and date of the payment and the names of the 
payer and the intended payee. The payer can obtain coins 
with such implicitly information-carrying yc L values 
simply by constructing them normally, and then exchanging 

25 other coins for them. In this context, however, the 
payment information need not even be sent to the bank, 
since it is implicitly contained in x ± . Hence, the only 
information that the payer needs to pass securely to the 
bank is the public signature key to be used to identify 

30 the payee, which implicitly communicates the requirements 
that the payer be non-anonymous. 

In fact, even this latter requirement of 
signature-based payee identification can be eliminated if 
information is embedded in x L (or ffx^) that the bank is 

35 not to honor the cash non-anonymously. For example, some 
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property of x L (e.g. the value of the first bit being 1) 
might be publicly declared by the bank to indicate that 
the coin in question will only be honored non- 
anonymously. A payer can then generate a secret x L by 
5 computing f(Sj), where Sj is the concatenation of the 
payment information for an intended transaction with some 
random value r, chosen such that x L has the non-anonymity 
property. Note that the property should be chosen such 
that roughly half the pre-images s^ of f (s) of any 

10 particular length result in an f (Sj) with the property , 
so that not many attempts to choose r will be necessary 
before one is found that has the desired effect on x L ) . 
This coin would now have the property that anyone 
presenting it for redemption must also provide an 

15 identity and prove it to the bank's satisfaction so that 
the bank can record the identity of the exchanger as part 
of its normal accounting. As a result, the coin's 
creator would later be able to demonstrate its origin, as 
well as other details of the transaction in which it was 

20 intended to be used, by referring to the bank's 

accounting records and revealing the s^ used to generate 
x L . Hence, even if the coin is spent completely 
normally, with no extra encryption or attendant 
information for the bank, it still provides the payer 

25 with all the protection furnished by the "electronic 
money order" described earlier. 
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Claims : 
What is claimed is: 

1. An electronic cash protocol comprising the 
steps of: 

5 using a one-way function f x (x) to generate an 

image f 1 (x 1 ) from a pre image x x ; 

sending the image f^x^ in an unblinded form to a 
second party; and 

receiving from the second party a note including a 
10 digital signature, said note representing a commitment by 
the second party to credit a predetermined amount of 
money to a first presenter of said preimage x x to the 
second party. 

2. The electronic cash protocol of claim 1 
15 further comprising sending the preimage x a to a third 

party as payment for purchase of goods or services from 
the third party. 

3. The electronic cash protocol of claim 1 
further comprising: 

20 selecting a second preimage x 2 ; 

using a second one-way function f 2 (x)to generate a 
second image f 2 (x 2 ) from the second preimage x 2 ; 

sending the first preimage x 1 and the unblinded 
form of the second image f 2 (x 2 ) to the second party; and 

25 receiving from the second party a second note 

including a digital signature, said second note 
representing a commitment by the second party to credit 
said predetermined amount of money to a first presenter 
of said second preimage x 2 to the second party. 

30 4. The electronic cash protocol of claim 3 

wherein f^x) and f 2 (x) are the same function* 
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5. The electronic cash protocol of claim 4 
wherein the step of sending the first preimage x x and the 
unblinded form of the second image f 2 (x 2 ) to the second 
party is performed anonymously. 

6. The electronic cash protocol of claim 5 
wherein the second party is a bank. 

7. The electronic cash protocol of claim 3 
further comprising sending the second preimage x 2 to a 
third party as payment for purchase of goods or services 
from the third party. 

8. The electronic cash protocol of claim 1 
further comprising: 

concatenating a signature key of a third party 
with the first preimage x x to form a block of 
information; 

encrypting the block of information by using 
an encryption key of the second party to generate an 
encrypted block of information; and 

sending the encrypted block of information to the 
third party, 

9. An electronic cash protocol comprising the 
steps of: 

receiving a first preimage x x from a first party , 
said preimage x x producing a first image f 1 (x 1 ) when 
processed by a first one-way function f^x) and there 
being associated with said first preimage x x a commitment 
by a second party to credit a predetermined amount of 
money to a first presenter to the second party of said 
first preimage x x ; 

selecting a second preimage x 2 ; 
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using a second one-way function f 2 (x)to generate a 
second image f 2 (x 2 ) from the second preimage x 2 ; 

sending the first preimage x x and an unblinded 
form of the second image f 2 (x 2 ) to the second party; and 
5 receiving from the second party a note including a 

digital signature, said note representing a commitment by 
the second party to credit said predetermined amount of 
money to a first presenter of said second preimage x 2 to 
the second party. 

10 10. The electronic cash protocol of claim 9 

wherein f^x) and f 2 (x) are the same function. 

11. The electronic cash protocol of claim 9 
wherein the step of sending the first preimage x x and the 
unblinded form of the second image f 2 (x 2 ) to the second 

15 party is performed anonymously. 

12. An electronic cash protocol comprising the 
steps of: 

receiving from a first party an encrypted block of 
information, wherein said block of encrypted information 
20 was generated by first concatenating a public signature 
key of a second party with a first preimage x x to form a 
block of information and then encrypting the block of 
information by using an encryption key of a third party; 
selecting a second preimage x 2 ; 
25 using a second one-way function f 2 (x) to generate 

an image f (x 2 ) from the preimage x 2 ; 

forming a message including the encrypted block of 
information along with the image f (x 2 ) in an unblinded 
form; 

30 sending the message to the third party; and 

receiving from the third party a signed note 
including a digital signature, said note representing a 
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commitment by the third party to credit a predetermined 
amount of money to a first presenter of said preimage x 2 
to the third party. 

13 . The electronic cash protocol of claim 12 
5 wherein f x (x) and f 2 (x) are the same function. 

14. The electronic cash protocol of claim 12 
further comprising signing the message before sending it 
to the third party, wherein the step of signing is 
performed using a private signature key corresponding to 

10 a public signature key possessed by the third party, 

15. The electronic cash protocol of claim 12 
wherein the second party is the party receiving the 
encrypted block of information from the first party. 

16. An electronic cash protocol comprising the 
15 steps of: 

receiving from a first entity an unblinded form of 
an image t 1 (^ 1 ) that was generated by applying a one-way 
function f^x) to a preimage x x ; 

generating a message which contains a commitment 
20 to credit a predetermined amount of money to a first 
presenter of said preimage x x ; 

signing said message with a digital signature; and 

sending said message along with said digital 
signature to said first party. 

25 17. The electronic cash protocol of claim 16 

wherein the receiving party maintains an account for the 
first entity and wherein said protocol further comprises 
debiting the first party' s account by the predetermined 
amount of money. 
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18. The electronic cash protocol of claim 16 
further comprising: 

subsequently receiving the pre image x^ from a 
third party; 

5 checking a database for the pre image x 1# * 

if the preimage x x is not found in said database, 

crediting the third party with said predetermined amount 

of money; and 

adding the preimage x x to said database. 

10 19. The electronic cash protocol of claim 16 

further comprising: 

subsequently receiving the preimage x x and am 
unblinded image f 2 (x 2 ) from a third party, wherein the 
unblinded image f 2 (x 2 ) was generated by applying a one-way 
15 function f 2 (x) to a preimage x 2 ; 

checking a database for the preimage x x ; 
if the preimage x x is not found in said database, 
generating a signed note including a digital signature, 
said note representing a commitment to credit said 
20 predetermined amount of money to a first presenter of 
said preimage x 2 ; and 

adding the preimage x 1 to said database. 

" 20. The electronic cash protocol of claim 19 
wherein f x (x) and f 2 (x) are the same function. 

25 21. The electronic cash protocol of claim 16 

further comprising: 

receiving a message from a second party, wherein 
said message was generated by concatenating an encryption 
key of a third party with a first preimage x 2 to form a 

30 block of information, by encrypting the block of 

information by using a first encryption key to generate 
an encrypted first block, and by concatenating an 
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unblinded image f 2 (x 2 ) to the encrypted first block of 
information, wherein said unblinded image f 2 (x 2 ) was 
generated by using a one-way function f 2 (x) to generate 
an image f 2 (x 2 ) from a preimage x 2 ; 
5 decrypting the encrypted first block of 

information; 

generating a note including a digital signature, 
said note representing a commitment to credit a 
predetermined amount of money to a first presenter of 
10 said preimage x 2 ; and 

sending said note to the second party. 

22. The electronic cash protocol of claim 21 
wherein f 1 (x) and f 2 (x) are the same function. 

23. The electronic cash protocol of claim 21 
15 further comprising: 

checking a database for the preimage x x ; 
generating the signed note only if the preimage x x 
is not found in said database; and 

adding the preimage x x to said database. 

20 24. An electronic cash protocol comprising the 

steps of: 

obtaining a first image f (x x ) and a first preimage 
x 1# wherein said first preimage x x has a predetermined 
monetary value associated therewith; 
25 selecting a second preimage x 2 ; 

using a second one-way function f 2 (x)to generate a 
second image f 2 (x 2 ) from the second preimage x 2 ; 

sending the first preimage x x and an unblinded 
form of the second image f 2 (x 2 ) to the second party; and 
30 receiving from the second party a note including a 

digital signature, said note representing a commitment by 
the second party to credit a predetermined amount of 
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money to a first presenter of said second preimage x 2 to 
the second party, wherein said predetermined amount of 
money is no greater than said predetermined monetary 
value. 

5 25. The electronic cash protocol of claim 24 

wherein said predetermined amount of money is less than 
said predetermined monetary value. 

26. The electronic cash protocol of claim 24 
wherein f^x) and f 2 (x) are the same function. 

10 27. An electronic cash protocol comprising the 

steps of: 

obtaining a first image f (x x ) and a first preimage 
x lf wherein said first preimage x a has a predetermined 
monetary value associated therewith; 

15 selecting a plurality of preimages x ± , wherein I 

is an integer index that runs from 1 to n, where n is a 
positive integer; 

using a second one-way function f 2 (x) to generate 
a plurality of images f 2 (Xi) from the second preimages x L ; 

20 sending the first preimage x x and an unblinded 

form of all of the images f 2 (x i ) to the second party; and 

receiving from the second party a plurality of 
notes each including a digital signature, said plurality 
of notes equal in number to the plurality of images t 2 ( x 0 

25 and representing a plurality of predetermined amounts, 
each of said plurality of notes representing a commitment 
by the second party to credit a corresponding different 
one of said plurality of predetermined amounts of money 
to a first presenter of the corresponding preimage x L to 

30 the second party, wherein the total of said plurality of 
predetermined amounts of money equals said predetermined 
monetary value. 
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28. An electronic cash protocol comprising the 
steps of: 

obtaining a first image f (x ± ) and a first preimage 
x 1# wherein said first preimage x x has a predetermined 
5 monetary value associated therewith; 

concatenating a signature key of a second party 
with the first preimage x x to form a block of 
information; 

encrypting the block of information by using 
10 an encryption key of a third party to generate an 
encrypted block of information; and 

sending the encrypted block of information to the 
third party. 

29. The electronic cash protocol of claim 28 
15 further comprising concatenating other information with 

the signature key of a second party and the first 
preimage x x to form the block of information. 

30. An electronic cash protocol comprising the 
steps of: 

20 sending an unblinded image f 2 (x 2 ) to a second 

party, wherein the unblinded image f 2 (x 2 ) was generated by 
applying a one-way function f 2 (x) to a preimage x 2 ; 

receiving a signed note from the second party, 
said unblinded note including a digital signature, said 

25 unblinded note representing a commitment to credit said 
predetermined amount of money to a first presenter of 
said preimage x 2 ; and 

in response to receiving the unblinded note from 
the second party, authorizing the delivery of goods 

30 and/or services to a third party. 



WO 97/09688 




PCT/US96/14078 




1/2 

"Please assign $50 to f(x)" f 








CUSTOMER 




BANK 




^ . 





10 



preimage of f(x] ) will be credited $50; 30 
Signed, The Bank" FIG. 1 



CUSTOMER 



x 1; f(xi), C(f(xi)), f(x2) 




C(f(x2))= "The first presenter of the 
preimage of f(x2) will be credited $50; FIG. 2 
Signed, The Bank" 









30 


BANK 






EXCHANGE 


PROTOCOL 




10 

f 




xi, f(xi), C(f(Xl)) 






20 












CUSTOMER 




VENDOR 



FIG. 3 



20 



VENDOR 



XT,f(xi), C(f(xi)), DEPOSTIT REQUEST 



30 

j_ 




DEPOSIT RECEIPT 



FIG. 4 



SUBSTITUTE SHEET (RULE 26) 



WO 97/09688 



PCT/US96/14078 



2/2 



EXCHANGE PROTOCOL 




GOODS PURCHASED 



FIG. 5 



x^fU,), C(f( X1 )), 
Vendor's SPK, 
Other Information 



10 




f(x 2 ), signed with SPK 



CUSTOMER 




VENDOR 




GOODS PURCHASED 





FIG. 6 



10 



CUSTOMER 



(E,f(x2)) signed with 
Vendor's SPK 




E=(|xi ,f(xi ), C(f (x, )), Vendor's SPK, 
Other Info] encrypted using Bank's 
public key) 



GOODS PURCHASED 



FIG. 7 



SUBSTITUTE SHEET (RULE 26) 



